// pages/index/index.js
import request from '../../utils/request'

Page({

  /**
   * 页面的初始数据
   */
  data: {
    bannerList: [], // 轮播图数据
    recommendList: [], // 推荐歌单
    topList: [], // 排行榜数据
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: async function (options) {
    //轮播图数据请求
    let bannerListData = await request('/banner', { type: 1 });//await为等待request这个异步任务，与async搭配使用
    this.setData({
      bannerList: bannerListData.banners
    })
    // console.log('结果数据：',bannerListData)
    //推荐歌单数据请求
    let recommendListData = await request('/personalized', { limit: 10 });//await为等待request这个异步任务，与async搭配使用
    this.setData({
      recommendList: recommendListData.result
    })
    //排行榜数据请求
    /*
* 需求分析：
*   1. 需要根据idx的值获取对应的数据
*   2. idx的取值范围是0-20， 我们需要0-4
*   3. 需要发送5次请求
* 前++ 和 后++的区别
*   1. 先看到是运算符还是值
*   2. 如果先看到的是运算符就先运算再赋值
*   3. 如果先看到的值那么就先赋值再运算
* */
    let index = 0;
    let resultArr = [];
    while (index < 6) {
      let topListData = await request('/top/list', { idx: index++ });//await为等待request这个异步任务，与async搭配使用
      // splice(会修改原数组，可以对指定的数组进行增删改) slice(不会修改原数组)
      let topListItem = { name: topListData.playlist.name, tracks: topListData.playlist.tracks.slice(0, 3) }
      resultArr.push(topListItem)
      // 不需要等待五次请求全部结束才更新，用户体验较好，但是渲染次数会多一些
      this.setData({
        topList: resultArr
      })
    }
    //更新topList的状态值,放在此处更新会导致发送请求的过程中页面长时间白屏，用户体验差，建议放在while中更新
    // this.setData({
    //   topList: resultArr
    // })
  },
  //跳转至recommendSong页面
  toRecommendSong() {
    wx.navigateTo({
      url: '/pages/recommendSong/recommendSong',
    })
  },

  // onLoad: function (options) {
  //   request('/banner', { type: 2 }).then(res => {
  //     const bannerList = res.data.banners 
  //     this.setData({
  //       bannerList
  //     })
  //     console.log(res.data)
  //   }).catch(err => {
  //     console.log(err)
  //   })
  // },
  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady: function () {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow: function () {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide: function () {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload: function () {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh: function () {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom: function () {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage: function () {

  }
})